草庐IT

php - SQL 到 ActiveRecord 条件

全部标签

sql - SQL 查询的最大长度

SELECTf.*FROMfeedsf,user_feedsufWHERE(f.id=uf.feed_idanduf.user_idin(1,2,5,6,23,45))ORDERBYcreated_atDESC这是用于构建用户提要的查询。这个查询的问题是“uf.user_idin()”随着用户关注的用户数量的增加而增加。SQL查询允许的最大长度是多少?有没有更好的方法来实现上面的查询?注意:我正在使用ActiveRecord和Postgres。 最佳答案 PostgreSQL可以处理的查询的最大长度是2147483648个字符(带符

ruby - ActiveRecord 连接警告。 (数据库连接不会自动关闭)

我正在尝试使用Sinatra和ActiveRecord(3.2.3)创建一个小应用。这是我的主文件的样子:require"sinatra"require"sinatra/reloader"require"active_record"...ActiveRecord::Base.establish_connection(adapter:'sqlite3',database:'db.sqlite3',host:'localhost',)classPost它有效,但有时我会在控制台中收到警告:DEPRECATIONWARNING:Databaseconnectionswillnotbeclos

ruby-on-rails - 有没有一种方法可以在不首先实例化对象的情况下验证 ActiveRecord 上的特定属性?

例如,如果我有一个用户模型并且我只需要验证登录(这可能发生在通过ajax验证表单时),那么如果我使用用户模型中定义的相同模型验证而不实际实例化会很棒一个用户实例。所以在Controller中我可以编写如下代码User.valid_attribute?(:login,"loginvalue")无论如何我可以做到这一点吗? 最佳答案 由于验证是在实例上运行的(并且它们使用实例的错误属性作为错误消息的容器),所以您不能在没有实例化对象的情况下使用它们。话虽如此,您可以将此所需行为隐藏到类方法中:classUservalue)unlessm

ruby - Rails:猴子修补 ActiveRecord::Base 与创建模块

我正在通读TheRails4way(由ObieFernandez撰写),一本关于Rails的著名书籍,从我目前阅读的内容来看,我强烈推荐它。但是,有一个示例部分9.2.7.1:MultipleCallbackMethodsinOneClass让我感到困惑:请耐心等待,为了让每个人都清楚问题,我在这个问题中复制了书中描述的步骤。该部分讨论了ActiveRecord回调(before_create、before_update等),并且可以创建一个类来为您处理多个回调。列出的代码如下:classAuditordefinitialize(audit_log)@audit_log=audit_l

ruby-on-rails - ActiveRecord 迁移不填充 Postgres 物化 View

我有一个通过迁移创建的MATERIALIZEDVIEW。classMyView注意:我已经混淆了SELECT语句,请相信我它是有效的。这里要注意的重要部分是我已经显式调用了WITHDATA,因此应该立即填充并扫描View。这不会发生。迁移运行,如下所示==MyView:migrating==========================MyView:migrated(0.0763s)===============稍后在db:refresh中我们看到以下内容ReindexingSomething...ReindexqueuedReindexingAnother...Reindexque

ruby - 为 API 包装器实现类似 ActiveRecord 的关联

我最近写了ParseResource,它是Parse.com's的RubyAPI包装器REST接口(interface)。下面是一些基本用法:classPost"Helloworld",:author=>"Alan",:body=>"ipsolorem")这个项目还很年轻,我真正想要实现的一个功能是关联。像这样:classAuthor"Alan",:email=>"alan@example.com")p=Post.create(:title=>"Associated!",:body=>"ipsolorem",:author=>a)p.author.class#=>Authorp.aut

sql - 在 Rails 中使用连接执行 update_all

在这种情况下,Rails对原始SQL的抽象让我抓狂。在MySQL中我可以这样做:UPDATEFROMtasksAStLEFTJOINprojectsaspONt.project_id=p.idSETt.invoice_id=7WHEREp.organization_id==42ANDt.invoice_idISNULL我如何在Rails3.0.1中使用预先加载来做到这一点?我已经尝试了以下所有方法:Tasks.joins(:project).where('projects.organization_id'=>42,:invoice_id=>nil).update_all(:invoic

ruby - ActiveRecord::NoEnvironmentInSchemaError

我正在尝试在我新升级的应用程序(Rails5)上执行数据库相关操作,但我无法在本地执行破坏性数据库命令。railsdb:reset或railsdb:drop。具有以下数据的跟踪结果,railsdb:drop--trace**Invokedb:drop(first_time)**Invokedb:load_config(first_time)**Executedb:load_config**Invokedb:check_protected_environments(first_time)**Invokeenvironment(first_time)**Executeenvironment

sql - 如何查看 SQL ActiveRecord 生成的内容?

我想检查一些由ActiveRecord生成的查询,但我不需要实际运行它们。有没有办法在返回结果之前获取查询? 最佳答案 这两篇文章都应该可以帮助您做您想做的事。http://weblog.jamisbuck.org/2007/1/8/watching-activerecord-do-it-s-thinghttp://weblog.jamisbuck.org/2007/1/31/more-on-watching-activerecord 关于sql-如何查看SQLActiveRecord生

sql - 用于 250K+ 字符串的通配符搜索的 Fast(er) 方法

我在MySQL数据库中有一个英语词典,其中只有超过250K个条目,我正在使用一个简单的ruby​​前端在字符串的开头使用通配符来搜索它。到目前为止,我一直这样做:SELECT*FROMwordsWHEREwordLIKE'_e__o'甚至SELECT*FROMwordsWHEREwordLIKE'____s'我总是知道单词的确切长度,但除了一个字符之外的所有字符都可能是未知的。这比糖蜜慢,比没有前导通配符的类似查询慢大约15倍,因为无法使用该列的索引。我尝试了几种方法来缩小搜索范围。例如,我添加了26个额外的列,其中包含每个单词的单个字母计数,并首先使用这些列来缩小搜索范围。我也试过按